

# R65C02 IP Core Specification

Author: Jens Gutschmidt scantara2003@yahoo.de

Rev. 0.7 February 25, 2009





This page has been intentionally left blank.



#### **Revision History**

| Rev. | Date     | Author     | Description                                       |  |  |  |  |  |
|------|----------|------------|---------------------------------------------------|--|--|--|--|--|
| 0.1  | 12/18/06 | Jens       | First Draft                                       |  |  |  |  |  |
|      |          | Gutschmidt |                                                   |  |  |  |  |  |
| 0.2  | 01/02/07 | Jens       | Pictures of FSM's                                 |  |  |  |  |  |
|      |          | Gutschmidt |                                                   |  |  |  |  |  |
| 0.3  | 08/20/08 | Jens       | - Tables and timing diagrams                      |  |  |  |  |  |
|      |          | Gutschmidt | - Deleting pictures of FSM                        |  |  |  |  |  |
| 0.4  | 10/01/08 | Jens       | - New ideas for timing diagrams                   |  |  |  |  |  |
|      |          | Gutschmidt |                                                   |  |  |  |  |  |
| 0.5  | 01/02/09 | Jens       | - Textual changes / spell checking                |  |  |  |  |  |
|      |          | Gutschmidt | <ul> <li>Insert R6502_TC block diagram</li> </ul> |  |  |  |  |  |
| 0.6  | 02/01/09 | Jens       | - Work on Timing Diagrams                         |  |  |  |  |  |
|      |          | Gutschmidt |                                                   |  |  |  |  |  |
| 0.7  | 23/02/09 | Jens       | - Added new instruction codes                     |  |  |  |  |  |
|      |          | Gutschmidt | (Timing diagrams for all new op codes             |  |  |  |  |  |
|      |          |            | missing)                                          |  |  |  |  |  |



### **Contents**

#### ERROR! NO TABLE OF CONTENTS ENTRIES FOUND.

|   | INTRODUCTION | •• ±<br>- |
|---|--------------|-----------|
| 2 | ARCHITECTURE |           |
| 3 | OPERATION    | 6         |
|   | ADC          |           |
|   | AND          |           |
|   | ASL          | 9         |
|   | BBR          | 9         |
|   | BBS          | 10        |
|   | BCC          | 11        |
|   | BCS          | 12        |
|   | BEQ          |           |
|   | BIT          | 14        |
|   | <i>BMI</i>   | 15        |
|   | BNE          | 16        |
|   | <i>BPL</i>   | 16        |
|   | BRA          | 16        |
|   | BRK          | 16        |
|   | BVC          | 16        |
|   | BVS          | 16        |
|   | <i>CLC</i>   | 16        |
|   | CLD          | 16        |
|   | <i>CLI</i>   | 16        |
|   | CLV          | 16        |
|   | <i>CMP</i>   | 16        |
|   | <i>CPX</i>   | 16        |
|   | <i>CPY</i>   | 16        |
|   | DEC          | 10        |
|   | DEX          | 10        |
|   | <i>DEY</i>   | 10        |
|   | EOR          | 16        |
|   | <i>INC</i>   | 16        |
|   | <i>INX</i>   | 16        |
|   | INY          | 16        |
|   | <i>JMP</i>   | 16        |
|   | <i>JSR</i>   | 16        |
|   | LDA          | 16        |
|   | LDX          | 16        |
|   | LDY          | 16        |
|   | LSR          | 16        |
|   | NOP          | 16        |
|   | ORA          | 16        |
|   | PHA          | 16        |
|   | <i>PHP</i>   | 16        |
|   | <i>PHX</i>   | 16        |
|   | PHY          | 16        |



| PLA                                                                            |                                         |   |
|--------------------------------------------------------------------------------|-----------------------------------------|---|
| PLP                                                                            | 1                                       | ( |
| PLX                                                                            | 1                                       | Ć |
| <i>PLY</i>                                                                     | 1                                       | Ć |
| ROL                                                                            | 10                                      | Ć |
| ROR                                                                            |                                         | Ć |
| <i>RMB</i>                                                                     | 10                                      | Ć |
| RTI                                                                            |                                         | Ć |
| RTS                                                                            |                                         | Ć |
| SBC                                                                            | 1                                       | ť |
| SEC                                                                            |                                         |   |
| SED                                                                            |                                         |   |
| SEI                                                                            |                                         |   |
| SMB                                                                            |                                         |   |
| STA                                                                            |                                         |   |
| STX                                                                            |                                         |   |
| STY                                                                            |                                         |   |
| STZ                                                                            |                                         |   |
| TAX                                                                            |                                         |   |
| TAY                                                                            |                                         |   |
| TRB                                                                            |                                         |   |
| TSB                                                                            |                                         |   |
| TSX                                                                            |                                         |   |
| TSA                                                                            |                                         |   |
|                                                                                |                                         |   |
| TXSTYA                                                                         |                                         |   |
| RegistersList of Registers                                                     | 10                                      | Ć |
| Register 1 – Description                                                       | 10                                      | ( |
|                                                                                |                                         |   |
| Clocks                                                                         |                                         | Ć |
| PENDIX A                                                                       | 16                                      |   |
| MING DIAGRAMS                                                                  | 16                                      |   |
|                                                                                |                                         |   |
| ADC, SBC                                                                       |                                         |   |
| AND, BIT, CMP, CPX, CPY, EOR, LDA, LDX, LDY, ORA                               |                                         |   |
| BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE                                         |                                         |   |
| BRK                                                                            |                                         |   |
| ASL, LSR, ROL, ROR, DEC, INC                                                   |                                         |   |
| CLC, CLD, CLI, CLV, DEX, DEY, INX, INY, SEC, SED, SEI, TAX, TAY, TSX, TXA, TYA |                                         |   |
| <i>JMP</i>                                                                     | 10                                      | ť |
| JSR                                                                            |                                         | ( |
| NOP, TXS                                                                       | 1                                       | ( |
| PLA, PLP                                                                       |                                         | ( |
| PHA, PHP                                                                       | 10                                      | ( |
| RTI                                                                            |                                         |   |
| RTS                                                                            |                                         |   |
| STA, STX, STY                                                                  |                                         |   |
| STRUCTION TABLE                                                                |                                         | - |
| yaay yaaya, aawaa ahaa ahaa ahaa ahaa ahaa ahaa a                              |                                         |   |
| EX                                                                             | 1                                       |   |
| 223                                                                            | • • • • • • • • • • • • • • • • • • • • |   |

| Figure (1): 6502 architecture                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | . 2 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Figure (2): R6502_TC IP core architecture                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | . 5 |
| Figure (3): ADC, SBC – Timing Diagram "Immediate"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 16  |
| Figure (4): ADC, SBC – Timing Diagram "Zero Page"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 16  |
| Figure (5): ADC, SBC – Timing Diagram "Zero Page, X"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 16  |
| Figure (6): ADC, SBC – Timing Diagram "Absolute"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 16  |
| Figure (7): ADC, SBC – Timing Diagram "Absolute, X" – no page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 16  |
| Figure (8): ADC, SBC – Timing Diagram "Absolute, X" – page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 16  |
| Figure (9): ADC, SBC – Timing Diagram "Absolute, Y" – no page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 16  |
| Figure (10): ADC, SBC – Timing Diagram "Absolute, Y" – page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 16  |
| Figure (11): ADC, SBC – Timing Diagram "(Indirect, X)"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 16  |
| Figure (12): ADC, SBC – Timing Diagram "(Indirect), Y" – no page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 16  |
| Figure (13): ADC, SBC – Timing Diagram "(Indirect), Y" – page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 16  |
| Figure (14): AND, CMP, CPX, CPY, EOR, LDA, LDX, LDY, ORA – Timing Diagram "Immediate "Im |     |
| Figure (15): AND, BIT, CMP, CPX, CPY, EOR, LDA, LDX, LDY, ORA – Timing Diagram "Ze Page"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ero |
| Figure (16): AND, CMP, EOR, LDA, LDY, ORA – Timing Diagram "Zero Page, X"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 16  |
| Figure (17): AND, BIT, CMP, CPX, CPY, EOR, LDA, LDX, LDY, ORA – Timing Diagra "Absolute"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| Figure (18): AND, CMP, EOR, LDA, LDY, ORA – Timing Diagram "Absolute, X" – no pacrossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| Figure (19): AND, CMP, EOR, LDA, LDY, ORA – Timing Diagram "Absolute, X" – page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 16  |
| Figure (20): AND, CMP, EOR, LDA, LDX, ORA – Timing Diagram "Absolute, Y" – no pacrossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | _   |
| Figure (21): AND, CMP, EOR, LDA, LDX, ORA – Timing Diagram "Absolute, Y" – page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 16  |
| Figure (22): AND, CMP, EOR, LDA, ORA – Timing Diagram "(Indirect, X)"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 16  |
| Figure (23): AND, CMP, EOR, LDA, ORA – Timing Diagram "(Indirect), Y" – no page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 16  |
| Figure (24): AND, CMP, EOR, LDA, ORA – Timing Diagram "(Indirect), Y" – page crossing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 16  |
| Figure (25): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE – Timing Diagram "no branch, sar page"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| Figure (26): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE – Timing Diagram "no branch, difference page"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| Figure (27): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE – Timing Diagram "branch, same pag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _   |



| Figure (28): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE – Timing Diagram "branch, dipage"                  |    |
|--------------------------------------------------------------------------------------------------------|----|
| Figure (29): BRK – Timing Diagram "Implied"                                                            | 16 |
| Figure (30): ASL A, LSR A, ROL A, ROR A – Timing Diagram "Immediate"                                   | 16 |
| Figure (31): ASL, LSR, ROL, ROR, DEC, INC – Timing Diagram "Zero Page"                                 | 16 |
| Figure (32): ASL, LSR, ROL, ROR, DEC, INC – Timing Diagram "Zero Page, X"                              | 16 |
| Figure (33): ASL, LSR, ROL, ROR, DEC, INC – Timing Diagram "Absolute"                                  | 16 |
| Figure (34): ASL, LSR, ROL, ROR, DEC, INC – Timing Diagram "Absolute, X"                               | 16 |
| Figure (35): CLC, CLD, CLI, CLV, DEX, DEY, INX, INY, SEC, SED, SEI, TAX, TAY, TSX TYA – Timing Diagram |    |
| Figure (36): JMP – Timing Diagram "Absolute"                                                           | 16 |
| Figure (37): JMP – Timing Diagram "Indirect"                                                           | 16 |
| Figure (38): JSR – Timing Diagram.                                                                     | 16 |
| Figure (39): NOP, TXS – Timing Diagram.                                                                | 16 |
| Figure (40): PLA, PLP – Timing Diagram "Implied".                                                      | 16 |
| Figure (41): PHA, PHP – Timing Diagram "Implied"                                                       | 16 |
| Figure (42): RTI – Timing Diagram "Implied".                                                           | 16 |
| Figure (43): RTS – Timing Diagram "Implied"                                                            | 16 |
| Figure (44): STA, STX, STY – Timing Diagram "Zero Page"                                                | 16 |
| Figure (45): STA, STY – Timing Diagram "Zero Page, X"                                                  | 16 |
| Figure (46): STX – Timing Diagram "Zero Page, Y"                                                       | 16 |
| Figure (47): STA, STX, STY – Timing Diagram "Absolute"                                                 | 16 |
| Figure (48): STA – Timing Diagram "Absolute, X"                                                        | 16 |
| Figure (49): STA – Timing Diagram "Absolute, Y"                                                        | 16 |
| Figure (50): STA – Timing Diagram "(Indirect, X)"                                                      | 16 |
| Figure (51): STA – Timing Diagram "(Indirect), Y"                                                      | 16 |
| LIST OF TABLES                                                                                         |    |
| Table (1): ADC – Short Reference                                                                       | 7  |
| Table (2): AND – Short Reference                                                                       | 8  |
| Table (3): ASL – Short Reference                                                                       | 9  |
| Table (4): BBR – Short Reference                                                                       | 9  |

| Table (5): BBS – Short Reference  | 10 |
|-----------------------------------|----|
| Table (6): BCC – Short Reference. | 11 |
| Table (7): BCS – Short Reference  | 12 |
| Table (8): BEQ – Short Reference. | 13 |
| Table (9): BIT – Short Reference  | 14 |
| Table (10): BMI – Short Reference | 15 |
| Table (11): BNE – Short Reference | 16 |
| Table (12): BPL – Short Reference | 16 |
| Table (13): BRA – Short Reference | 16 |
| Table (14): BRK – Short Reference | 16 |
| Table (15): BVC – Short Reference | 16 |
| Table (16): BVS – Short Reference | 16 |
| Table (17): CLC – Short Reference | 16 |
| Table (18): CLD – Short Reference | 16 |
| Table (19): CLI – Short Reference | 16 |
| Table (20): CLV – Short Reference | 16 |
| Table (21): CMP – Short Reference | 16 |
| Table (22): CPX – Short Reference | 16 |
| Table (23): CPY – Short Reference | 16 |
| Table (24): DEC – Short Reference | 16 |
| Table (25): DEX – Short Reference | 16 |
| Table (26): DEX – Short Reference | 16 |
| Table (27): EOR – Short Reference | 16 |
| Table (28): INC – Short Reference | 16 |
| Table (29): INX – Short Reference | 16 |
| Table (30): INY – Short Reference | 16 |
| Table (31): JMP – Short Reference | 16 |
| Table (32): JSR – Short Reference | 16 |
| Table (33): LDA – Short Reference | 16 |
| Table (34): LDX – Short Reference | 16 |
| Table (35): LDY – Short Reference | 16 |
| Table (36): LSR – Short Reference | 16 |
| Table (37): NOP – Short Reference | 16 |

| Table (38): OR – Short Reference   | 16 |
|------------------------------------|----|
| Table (39): PHA – Short Reference  | 16 |
| Table (40): PHP – Short Reference  | 16 |
| Table (41): PHX – Short Reference  | 16 |
| Table (42): PHY – Short Reference  | 16 |
| Table (43): PLA – Short Reference  | 16 |
| Table (44): PLP – Short Reference. | 16 |
| Table (45): PLX – Short Reference  | 16 |
| Table (46): PLY – Short Reference  | 16 |
| Table (47): ROL – Short Reference  | 16 |
| Table (48): ROR – Short Reference  | 16 |
| Table (49): RMB – Short Reference  | 16 |
| Table (50): RTI – Short Reference  | 16 |
| Table (51): RTS – Short Reference  | 16 |
| Table (52): SBC – Short Reference  | 16 |
| Table (53): SEC – Short Reference  | 16 |
| Table (54): CLD – Short Reference  | 16 |
| Table (55): SEI – Short Reference  | 16 |
| Table (56): SMB – Short Reference  | 16 |
| Table (57): STA – Short Reference  | 16 |
| Table (58): STX – Short Reference  | 16 |
| Table (59): STY – Short Reference  | 16 |
| Table (60): STZ – Short Reference  | 16 |
| Table (61): TAX – Short Reference  | 16 |
| Table (62): TAY – Short Reference  | 16 |
| Table (63): TRB – Short Reference  | 16 |
| Table (64): TSB – Short Reference  | 16 |
| Table (65): TSX – Short Reference  | 16 |
| Table (66): TXA – Short Reference  | 16 |
| Table (67): TXS – Short Reference  | 16 |
| Table (68): TYA – Short Reference  | 16 |





## 1 Introduction

The Central Processing Unit (CPU) 6502 was introduced at 1976 by Commodore Computers. It is an 8 Bit processor which is well known worldwide. The also most known computer system in the 70s/80s was the APPLE based on this famous 6502.

In this century building of little computer systems based on an 8 Bit architecture is easier than ever before. Many CAD/CAM tool are existing on the market to give you help to do this job.

In the last decade the technology give us more and more possibilities to reach our dreams – higher, faster, wider. FPGA's (Field Programmable Gate Arrays) and CPLD's (Complex Programmable Logic Devices) are coming up. They shortening the time of development, simulation and verification of such systems dramatically. On the other hand stands the rising complexility of designs and well knowing of desired description languages – VHDL (Very high scale integration Hardware Description Language) or Verilog.

Many operations and functions of computer tasks aren't need really the power of "modern" processors today like Intel's Pentium. Nevertheless it is not usable – some times also impossible - to build simple systems with discrete IC's. The necessity of flexibility compel us the using of high tech parts and tools...to build a "simple" system.

The using of standard IP's (Intellectual Properties) is the key to reach that goal.

Now talking about the specification of the **6502 True Cycle Core IP**. Written in VHDL but developed with Mentor's HDL Designer. The 6502 is very easy to handle for people were have experience with other cpu's. Also suitable for beginners who will learning to build her own first cpu system.



## 2 Architecture

The following figure shows the internal architecture of the Commodore's 6502.



Figure (1): 6502 architecture

First, for more clearance and better understanding of the **6502 True Cycle Core IP** let me summarize the most important quality of Commodore's 6502.

This architecture based on asynch logic. The two phase clock is a special attribute of that. The Data Bus is only active while clock phase PH1 is "1" for reading and writing (PH0 is "0"). All transfers of data are occur at active phase of PH1.



The whole 6502 is fully statically, so all registers holding her values if the clocking will be going to D.C. Internally all operation of 16 Bit are splitted into two 8 Bit busses. This is very interesting and causes one more clock cycle in some operations (see "PCL", "PCH" -> Program Counter Low/High) which can operate over page boundaries.

Address lines are 16 Bit wide. 65.536 addresses for byte access are possible. There are no differences exist between memory and I/O cycles. All I/O devices must be connected via memory mapped I/O. The mnemonics are also all the same for both. The usage of address space is normally organized form top to the button "ROM – I/O – RAM" (0xFFFF – 0x0000).

Only one pin R/W-controls the read and write operations.

The 6502 can hold in every cycle – except write cycles - by applying RDY. So wait states can be generate by using RDY.

There are two interrupts IRQ and NMI. IRQ is mask able, NMI is not. Note that RES is internally handled as an interrupt, but is resetting the 6502 to the starting point of operation at vector address 0xFFFF. Every interrupt has its own vector which can point elsewhere to the 16 Bit address space. The vectors are located from 0xFFFF to 0xFFFA.

The Stack Pointer is 256 Bytes deep and is hard-wired to 0x01FF (internally 0x0200 - 0x01FF going to the address bus) for the first memory location and grows downward to 0x0100. Decrementing again will produce a wrap around back to 0x01FF.

Arithmetical operations like ADC and SBC can handle binary values from 0-255 and decimal values from 0-99 without using other op codes. Only one user changeable bit into the Status Register determine the exact arithmetic mode of that operations.

The 6502 generally operates into a pipeline mode. That means that a finish of an OP code falls every time into a fetch cycle of the next OP. This save one clock cycle

Every operation consume between two and seven clock cycles.



To build an useful und backward software and hardware compatible VHDL Core for the 6502 many unavoidable changes may be forced to simulation and verification before any real core will be made.

#### The requirements:

- Vendor indepent for implementation in any FPGA
- True Cycle for all operations as described in original publications
- No "Mixed Mode" Only 6502, not 65C02 -> for performance and area
- No fantastic or useful extensions as like the original 6502 as possible
- Don't implement the "undocumented OP's" at this time -> goodie for future releases
- Only one clock
- Full synch design
- Operating speed up to 60 MHz or higher
- Easily to change for future requirement building variants
- The activity on data and address busses since the execution of OP codes is not forced to be like the original may be or may be not.

The design based on finite state machines (fsm). Every OP code has its own fsm. Some registers are for internally use only and stores temporally values. These registers are not accessible by the programmer.

Some fsm's own registers for internally use and don't share this registers with other fsm's. This help to decrease fan-in and increase performance.

The next picture shows the hierarchical structure of the R6502 IP core.



Figure (2): R6502\_TC IP core architecture Stack Pointer 8Bit

Address computation based on "-1", "+1" and setting new addresses by program control. Fixed to page 1 (0x01FF down to 0x0100).

Reg SP

#### Registerbank for A, X and Y

Flipflops for main registers with internal pathes for register-to-register transfers. **Rev 0.7 Preliminary** 

5 of 16

RegBank AXY

registe

ad

regi

unreg

Reg.

multi

www.opencores.org

6 of 16



## 3 Operation



#### **ADC**

Operation: Add memory or immediate value to accumulator A with carry  $(A + M + C \rightarrow A, C)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V         | Е | В | D | I | Z         | С         |
|-----------------|---------------------------|------------|--------------|---------------|---|-----------|---|---|---|---|-----------|-----------|
| Immediate       | ADC # Oper                | 69         | 2            | 2             |   | $\sqrt{}$ | - | - | - | - | $\sqrt{}$ | $\sqrt{}$ |
| Zero Page       | ADC Oper                  | 65         | 2            | 3             |   | $\sqrt{}$ | - | - | - | - | $\sqrt{}$ | $\sqrt{}$ |
| Zero Page, X    | ADC Oper, X               | 75         | 2            | 4             |   |           | - | - | - | - | $\sqrt{}$ | 1         |
| Absolute        | ADC Oper                  | 6D         | 3            | 4             |   |           | - | - | - | - | V         | $\sqrt{}$ |
| Absolute, X     | ADC Oper, X               | 7D         | 3            | 4*            |   | $\sqrt{}$ | - | - | - | - | V         | $\sqrt{}$ |
| Absolute, Y     | ADC Oper, Y               | 79         | 3            | 4*            |   |           | - | - | - | - | V         | 1         |
| (Indirect, X)   | ADC (Oper, X)             | 61         | 2            | 6             |   |           | - | - | - | - | V         | 1         |
| (Indirect), Y   | ADC (Oper), Y             | 71         | 2            | 5*            |   |           | - | - | - | - | $\sqrt{}$ | $\sqrt{}$ |
| (Indirect) NEW  | ADC (Oper)                | 72         | 2            | 5             |   |           | - | - | - | - |           | 1         |

<sup>\* =&</sup>gt; Add 1 if page boundary is crossed

Table (1): ADC – Short Reference

Example Immediate (assumed A=\$FE, C=0):

| Addres | SS | Bytes                                      | Mnemonic        |                                     |
|--------|----|--------------------------------------------|-----------------|-------------------------------------|
| \$9000 |    | 69 03                                      | ADC #\$03       |                                     |
| \$9002 |    |                                            | next OP         | ; A is now \$01, C=1, N=0, Z=0, V=0 |
| ADC    |    | 110 (\$FE)<br>011 (\$03)<br>001 (\$01), C= | :1, N=0, Z=0, V | <u>/=0</u>                          |



#### **AND**

Operation: "AND" memory or immediate value with accumulator A  $(A \cap M \rightarrow A)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N         | V | E | В | D | I | Z         | С |
|-----------------|---------------------------|------------|--------------|---------------|-----------|---|---|---|---|---|-----------|---|
| Immediate       | AND #Oper                 | 29         | 2            | 2             | $\sqrt{}$ | - | - | - | - | - | $\sqrt{}$ | - |
| Zero Page       | AND Oper                  | 25         | 2            | 3             | $\sqrt{}$ | - | - | - | - | - | $\sqrt{}$ | - |
| Zero Page, X    | AND Oper, X               | 35         | 2            | 4             | $\sqrt{}$ | - | - | - | - | - | $\sqrt{}$ | - |
| Absolute        | AND Oper                  | 2D         | 3            | 4             | $\sqrt{}$ | - | - | - | - | - | V         | - |
| Absolute, X     | AND Oper, X               | 3D         | 3            | 4*            | $\sqrt{}$ | - | - | - | - | - | $\sqrt{}$ | - |
| Absolute, Y     | AND Oper, Y               | 39         | 3            | 4*            |           | - | - | - | - | - | V         | - |
| (Indirect, X)   | AND (Oper, X)             | 21         | 2            | 6             | $\sqrt{}$ | - | - | - | - | - | $\sqrt{}$ | - |
| (Indirect), Y   | AND (Oper), Y             | 31         | 2            | 5*            | $\sqrt{}$ | - | - | - | - | - | $\sqrt{}$ | - |
| (Indirect) NEW  | AND (Oper)                | 32         | 2            | 5             |           | - | - | - | - | - | $\sqrt{}$ | - |

<sup>\* =&</sup>gt; Add 1 if page boundary is crossed

Table (2): AND – Short Reference

#### Example Immediate (assumed A is \$C5):

| Address | Bytes | Mnemonic  |                            |
|---------|-------|-----------|----------------------------|
| \$9000  | 29 71 | AND #\$71 | ;; A is now \$41, N=0, Z=0 |
| \$9002  |       | next OP   |                            |



#### **ASL**

Operation: Shift Left One Bit (Memory or Accumulator) (C  $\leftarrow$  7 6 5 4 3 2 1 0  $\leftarrow$  0)

| Addressing Mode | Assem<br>Form | bly Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z         | С         |
|-----------------|---------------|--------------|------------|--------------|---------------|---|---|---|---|---|---|-----------|-----------|
| Accumulator     | ASL           | A            | 0A         | 1            | 2             |   | - | - | - | - | - | V         | $\sqrt{}$ |
| Zero Page       | ASL           | Oper         | 06         | 2            | 5             |   | - | - | - | - | - | V         | $\sqrt{}$ |
| Zero Page, X    | ASL           | Oper, X      | 16         | 2            | 6             |   | - | - | - | - | - | V         | $\sqrt{}$ |
| Absolute        | ASL           | Oper         | 0E         | 3            | 6             |   | - | - | - | - | - | V         | $\sqrt{}$ |
| Absolute, X     | ASL           | Oper, X      | 1E         | 3            | 7             |   | - | - | - | - | - | $\sqrt{}$ | $\sqrt{}$ |

Table (3): ASL – Short Reference

Example Accumulator (assumed A=\$55):

| Address | Bytes | Mnemonic |                          |
|---------|-------|----------|--------------------------|
| \$9000  | 0A    | ASL A    | •                        |
| \$9001  |       | next OP  | ; A is now \$AA, N=1, Z= |

<u>ASL 0101 0101 (\$55)</u> <u>1010 1010 (\$AA), C=0, N=1, Z=0</u>

#### **BBR**

Operation: Branch on memory bit x is reset, where x=0-7 MSB of op code (Branch on Mx=0)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BBR(0-7) ZP,offs8         | 0F-7F      | 3            | 5*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (4): BBR - Short Reference

Example Relative (assumed \$0032=\$24, same page):

| Address | Bytes    | Mnemonic        |                                                     |
|---------|----------|-----------------|-----------------------------------------------------|
| \$9000  | 2F 32 10 | BBR2 \$32, \$10 | ; BBR to same page, - NO BRANCH - jumps to ; \$9003 |
| \$9003  | •••      | next OP         | M2(\$0032) = 1 = no branch, 5  cycles               |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



Example Relative (assumed \$0032=\$24, different page):

| Address | Bytes    | Mnemonic        |                                                                         |
|---------|----------|-----------------|-------------------------------------------------------------------------|
| \$90FF  | 5F 32 10 | BBR5 \$32, \$10 | ; BBR to different page, - NO BRANCH – jumps ; to \$9102                |
| \$9102  |          | next OP         | ; $M5(\$0032) = 1 \Rightarrow \text{no branch}, 5 \text{ cycles} (!!!)$ |

Example Relative (assumed \$0032=\$24, same page):

| Address | Bytes    | Mnemonic        |                                                           |
|---------|----------|-----------------|-----------------------------------------------------------|
| \$9000  | 0F 32 10 | BBR0 \$32, \$10 | ; BBR to same page, - BRANCH - jumps to \$9003 ; + $\$10$ |
| \$9013  | •••      | next OP         | ; M0(\$0032)=0 => branch, 6 cycles                        |

Example Relative (assumed \$0032=\$24, different page):

| Address | Bytes    | <u>Mnemonic</u> |                                                                |
|---------|----------|-----------------|----------------------------------------------------------------|
| \$90FF  | 0F 32 10 | BBR0 \$32, \$10 | ; BBR to different page, - BRANCH - jumps to ; $\$9102 + \$10$ |
| \$9112  | •••      | next OP         | ; M0(\$0032)=0 => branch, 7 cycles                             |

#### **BBS**

Operation: Branch on memory bit x is set, where x=0.7 MSB-8 of op code (Branch on Mx=1)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | C |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BBS(0-7) ZP,offs8         | 0F-7F      | 3            | 5*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (5): BBS – Short Reference

Example Relative (assumed \$0032=\$24, same page):

| Address | <u>Bytes</u> | Mnemonic        |                                                     |
|---------|--------------|-----------------|-----------------------------------------------------|
| \$9000  | 8F 32 10     | BBS0 \$32, \$10 | ; BBS to same page, - NO BRANCH - jumps to ; \$9003 |
| \$9003  | •••          | next OP         | 0.5 + 0.03; M0(\$0032) =0 => no branch, 5 cycles    |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



Example Relative (assumed \$0032=\$24, different page):

| Address | Bytes    | Mnemonic        |                                                                        |
|---------|----------|-----------------|------------------------------------------------------------------------|
| \$90FF  | FF 32 10 | BBS7 \$32, \$10 | ; BBS to different page, - NO BRANCH – jumps ; to \$9102               |
| \$9102  | •••      | next OP         | $M7(\$0032) = 0 \Rightarrow \text{no branch}, 5 \text{ cycles } (!!!)$ |

Example Relative (assumed \$0032=\$24, same page):

| Address | Bytes    | Mnemonic        |                                                            |
|---------|----------|-----------------|------------------------------------------------------------|
| \$9000  | AF 32 10 | BBS2 \$32, \$10 | ; BBS to same page, - BRANCH - jumps to \$9003 ; + $\$10$  |
| \$9013  | •••      | next OP         | $M2(\$0032)=1 \Rightarrow \text{branch}, 6 \text{ cycles}$ |

Example Relative (assumed \$0032=\$24, different page):

| Address | Bytes    | Mnemonic        |                                                                |
|---------|----------|-----------------|----------------------------------------------------------------|
| \$90FF  | DF 32 10 | BBS5 \$32, \$10 | ; BBS to different page, - BRANCH - jumps to ; $\$9102 + \$10$ |
| \$9112  |          | next OP         | ; M5(\$0032)=1 => branch, 7 cycles                             |

#### **BCC**

Operation: Branch on Carry Clear (Branch on C = 0)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BCC Oper                  | 90         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (6): BCC – Short Reference

Example Relative (assumed C=1, same page):

| Address          | Bytes     | Mnemonic         |                                                                                |
|------------------|-----------|------------------|--------------------------------------------------------------------------------|
| \$9000<br>\$9002 | 90 10<br> | BCC \$10 next OP | ; BCC to same page, - NO BRANCH - jumps to \$9002 ; C=1 => no branch, 2 cycles |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



Example Relative (assumed C=1, different page):

| Address | Bytes | Mnemonic |                                                          |
|---------|-------|----------|----------------------------------------------------------|
| \$90FF  | 90 10 | BCC \$10 | ; BCC to different page, - NO BRANCH - jumps to ; \$9101 |
| \$9101  |       | next OP  | ; C=1 => no branch, 2 cycles (!!!)                       |

Example Relative (assumed C=0, same page):

| Address | Bytes | Mnemonic |                                                         |
|---------|-------|----------|---------------------------------------------------------|
| \$9000  | 90 10 | BCC \$10 | ; BCC to same page, - BRANCH - jumps to $\$9002 + \$10$ |
| \$9012  |       | next OP  | ; C=0 => branch, 3 cycles                               |

Example Relative (assumed C=0, different page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$90FF  | 90 10 | BCC \$10 | ; BCC to different page, - BRANCH - jumps to ; \$9111 |
| \$9111  |       | next OP  | ; C=0 => branch, 4 cycles                             |

#### **BCS**

Operation: Branch on Carry Set (Branch on C = 1)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BCS Oper                  | В0         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (7): BCS – Short Reference

#### Example Relative (assumed C=0, same page):

| Address | Bytes | Mnemonic |                                                   |
|---------|-------|----------|---------------------------------------------------|
| \$9000  | B0 10 | BCS \$10 | ; BCS to same page, - NO BRANCH - jumps to \$9002 |
| \$9002  | •••   | next OP  | ; C=0 => no branch, 2 cycles                      |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



Example Relative (assumed C=0, different page):

| <u>Address</u> | Bytes | Mnemonic |                                                          |
|----------------|-------|----------|----------------------------------------------------------|
| \$90FF         | B0 10 | BCS \$10 | ; BCS to different page, - NO BRANCH - jumps to ; \$9101 |
| \$9101         |       | next OP  | ; C=0 => no branch, 2 cycles (!!!)                       |

Example Relative (assumed C=1, same page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$9000  | B0 10 | BCS \$10 | ; BCS to same page, - BRANCH - jumps to \$9002 + \$10 |
| \$9012  | •••   | next OP  | ; C=1 => branch, 3 cycles                             |

Example Relative (assumed C=1, different page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$90FF  | B0 10 | BCS \$10 | ; BCS to different page, - BRANCH - jumps to : \$9111 |
| \$9111  |       | next OP  | ; C=1 => branch, 4 cycles                             |

#### **BEQ**

Operation: Branch on result zero (Branch on Z = 1)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BEQ Oper                  | F0         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (8): BEQ - Short Reference

Example Relative (assumed Z=0, same page):

| Address          | Bytes | Mnemonic            |                                                                                |
|------------------|-------|---------------------|--------------------------------------------------------------------------------|
| \$9000<br>\$9002 | F0 10 | BEQ \$10<br>next OP | ; BEQ to same page, - NO BRANCH - jumps to \$9002 ; Z=0 => no branch, 2 cycles |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



Example Relative (assumed Z=0, different page):

| Address | Bytes | Mnemonic |                                                          |
|---------|-------|----------|----------------------------------------------------------|
| \$90FF  | F0 10 | BEQ \$10 | ; BEQ to different page, - NO BRANCH - jumps to ; \$9101 |
| \$9101  |       | next OP  | ; Z=0 => no branch, 2 cycles (!!!)                       |

Example Relative (assumed Z=1, same page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$9000  | F0 10 | BEQ \$10 | ; BEQ to same page, - BRANCH - jumps to $$9002 + $10$ |
| \$9012  |       | next OP  | $Z=1 \Rightarrow \text{branch}, 3 \text{ cycles}$     |

Example Relative (assumed Z=1, different page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$90FF  | F0 10 | BEQ \$10 | ; BEQ to different page, - BRANCH - jumps to : \$9111 |
| \$9111  |       | next OP  | ; $Z=1 \Rightarrow$ branch, 4 cycles                  |

#### **BIT**

Operation: Bit 6 and 7 are transferred to the status register. If the result of  $A \cap M$  then Z = 1, otherwise Z = 0 ( $A \cap M \rightarrow A$ ,  $M7 \rightarrow N$ ,  $M6 \rightarrow V$ )

| Addressing Mo | ode | Asser<br>Form | nbly Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|---------------|-----|---------------|---------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Immediate     | NEW | BIT           | # Oper        | 89         | 2            | 2             | - | - | - | - | - | - | V | - |
| Zero Page     |     | BIT           | Oper          | 24         | 2            | 3             | 7 | 6 | - | - | - | - | V | - |
| Zero Page, X  | NEW | BIT           | Oper, X       | 34         | 2            | 4             | 7 | 6 | - | - | - | - | V | - |
| Absolute      |     | BIT           | Oper          | 2C         | 3            | 4             | 7 | 6 | - | - | - | - | V | 1 |
| Absolute, X   | NEW | BIT           | Oper, X       | 3C         | 3            | 4*            | 7 | 6 | - | - | - | - | V | - |

\* => Add 1 if page boundary is crossed

Table (9): BIT – Short Reference

#### In mode "Immediate" BIT leaves flags N&V unchanged. This is a special case on R65C02!



#### **BMI**

Operation: Branch on result minus (Branch on N = 1)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BMI Oper                  | 30         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (10): BMI – Short Reference

#### Example Relative (assumed Z=0, same page):

| Address | Bytes | Mnemonic |                                                   |
|---------|-------|----------|---------------------------------------------------|
| \$9000  | 30 10 | BMI \$10 | ; BMI to same page, - NO BRANCH - jumps to \$9002 |
| \$9002  |       | next OP  | ; N=0 => no branch, 2 cycles                      |

#### Example Relative (assumed Z=0, different page):

| Address | Bytes | Mnemonic |                                                          |
|---------|-------|----------|----------------------------------------------------------|
| \$90FF  | 30 10 | BMI \$10 | ; BMI to different page, - NO BRANCH - jumps to ; \$9101 |
| \$9101  |       | next OP  | ; N=0 => no branch, 2 cycles (!!!)                       |

#### Example Relative (assumed Z=1, same page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$9000  | 30 10 | BMI \$10 | ; BMI to same page, - BRANCH - jumps to $$9002 + $10$ |
| \$9012  |       | next OP  | ; N=1 => branch, 3 cycles                             |

#### Example Relative (assumed Z=1, different page):

| Address    | Bytes | Mnemonic |                                                       |
|------------|-------|----------|-------------------------------------------------------|
| \$90FF<br> | 30 10 | BMI \$10 | ; BMI to different page, - BRANCH - jumps to ; \$9111 |
| \$9111     |       | next OP  | ; $N=1 \Rightarrow$ branch, 4 cycles                  |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



#### **BNE**

Operation: Branch on result not zero (Branch on Z = 0)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BNE Oper                  | D0         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (11): BNE – Short Reference

#### Example Relative (assumed Z=1, same page):

| Address | Bytes | Mnemonic |                                                   |
|---------|-------|----------|---------------------------------------------------|
| \$9000  | D0 10 | BNE \$10 | ; BNE to same page, - NO BRANCH - jumps to \$9002 |
| \$9002  |       | next OP  | ; Z=1 => no branch, 2 cycles                      |

#### Example Relative (assumed Z=1, different page):

| Address | Bytes | Mnemonic |                                                          |
|---------|-------|----------|----------------------------------------------------------|
| \$90FF  | D0 10 | BNE \$10 | ; BNE to different page, - NO BRANCH - jumps to ; \$9101 |
| \$9101  |       | next OP  | ; Z=1 => no branch, 2 cycles (!!!)                       |

#### Example Relative (assumed Z=0, same page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$9000  | D0 10 | BNE \$10 | ; BNE to same page, - BRANCH - jumps to $$9002 + $10$ |
| \$9012  |       | next OP  | ; Z=0 => branch, 3 cycles                             |

#### Example Relative (assumed Z=0, different page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$90FF  | D0 10 | BNE \$10 | ; BNE to different page, - BRANCH - jumps to ; \$9111 |
| \$9111  | •••   | next OP  | ; Z=0 => branch, 4 cycles                             |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



#### **BPL**

Operation: Branch on result plus (Branch on N = 0)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BPL Oper                  | 10         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (12): BPL – Short Reference

Example Relative (assumed N=1, same page):

| Address | Bytes | Mnemonic |                                                   |
|---------|-------|----------|---------------------------------------------------|
| \$9000  | 10 10 | BPL \$10 | ; BPL to same page, - NO BRANCH - jumps to \$9002 |
| \$9002  |       | next OP  | ; N=1 => no branch, 2 cycles                      |

Example Relative (assumed N=1, different page):

| Address | Bytes | Mnemonic |                                                          |
|---------|-------|----------|----------------------------------------------------------|
| \$90FF  | 10 10 | BPL \$10 | ; BPL to different page, - NO BRANCH - jumps to ; \$9101 |
| \$9101  |       | next OP  | ; N=1 => no branch, 2 cycles (!!!)                       |

Example Relative (assumed N=0, same page):

| Address | Bytes | Mnemonic |                                                         |
|---------|-------|----------|---------------------------------------------------------|
| \$9000  | 10 10 | BPL \$10 | ; BPL to same page, - BRANCH - jumps to $\$9002 + \$10$ |
| \$9012  |       | next OP  | ; N=0 => branch, 3 cycles                               |

Example Relative (assumed N=0, different page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$90FF  | 10 10 | BPL \$10 | ; BPL to different page, - BRANCH - jumps to ; \$9111 |
| \$9111  |       | next OP  | ; N=0 => branch, 4 cycles                             |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



#### **BRA**

Operation: Branch allways (Branch allways)

| Addressing Mode     | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|---------------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative <i>NEW</i> | BRA Oper                  | 80         | 2            | 3*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to different page

Table (13): BRA – Short Reference

#### **BRK**

Operation: Forced Interrupt (PC +  $2 \downarrow$ , P  $\downarrow$ )

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | BRK                       | 00         | 1            | 7             | - | - | - | - | - | 1 | - | - |

Table (14): BRK – Short Reference

#### **BVC**

Operation: Branch on no overflow (Branch on V = 0)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BVC Oper                  | 50         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (15): BVC - Short Reference

Example Relative (assumed V=1, same page):

| Address | Bytes | Mnemonic |                                                   |
|---------|-------|----------|---------------------------------------------------|
| \$9000  | 50 10 | BVC \$10 | ; BVC to same page, - NO BRANCH - jumps to \$9002 |
| \$9002  |       | next OP  | ; V=1 => no branch, 2 cycles                      |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



Example Relative (assumed V=1, different page):

| Address | Bytes | Mnemonic |                                                             |
|---------|-------|----------|-------------------------------------------------------------|
| \$90FF  | 50 10 | BVC \$10 | ; BVC to different page, - NO BRANCH - jumps to : \$9101    |
| \$9101  |       | next OP  | $V=1 \Rightarrow \text{no branch}, 2 \text{ cycles } (!!!)$ |

Example Relative (assumed V=0, same page):

| Address | Bytes | Mnemonic |                                                         |
|---------|-------|----------|---------------------------------------------------------|
| \$9000  | 50 10 | BVC \$10 | ; BVC to same page, - BRANCH - jumps to $\$9002 + \$10$ |
| \$9012  |       | next OP  | ; $V=0 \Rightarrow$ branch, 3 cycles                    |

Example Relative (assumed V=0, different page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$90FF  | 50 10 | BVC \$10 | ; BVC to different page, - BRANCH - jumps to : \$9111 |
| \$9111  |       | next OP  | ; V=0 => branch, 4 cycles                             |

#### **BVS**

Operation: Branch on overflow (Branch on V = 1)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Relative        | BVS Oper                  | 70         | 2            | 2*            | - | - | - | - | - | - | - | - |

<sup>\* =&</sup>gt; Add 1 if branch occurs to same page

Table (16): BVS – Short Reference

#### Example Relative (assumed V=0, same page):

| Address | Bytes | Mnemonic |                                                                                |
|---------|-------|----------|--------------------------------------------------------------------------------|
| \$9000  | 70 10 | BVS \$10 | ; BVS to same page, - NO BRANCH - jumps to \$9002 ; V=0 => no branch, 2 cycles |
| \$9002  |       | next OP  |                                                                                |

<sup>\* =&</sup>gt; Add 2 if branch occurs to different page



Example Relative (assumed V=0, different page):

| Address | Bytes | Mnemonic |                                                          |
|---------|-------|----------|----------------------------------------------------------|
| \$90FF  | 70 10 | BVS \$10 | ; BVS to different page, - NO BRANCH - jumps to ; \$9101 |
| \$9101  | •••   | next OP  | ; V=0 => no branch, 2 cycles (!!!)                       |

Example Relative (assumed V=1, same page):

| Address | Bytes | Mnemonic |                                                         |
|---------|-------|----------|---------------------------------------------------------|
| \$9000  | 70 10 | BVS \$10 | ; BVS to same page, - BRANCH - jumps to $\$9002 + \$10$ |
| \$9012  |       | next OP  | ; $V=1 \Rightarrow$ branch, 3 cycles                    |

Example Relative (assumed V=1, different page):

| Address | Bytes | Mnemonic |                                                       |
|---------|-------|----------|-------------------------------------------------------|
| \$90FF  | 70 10 | BVS \$10 | ; BVS to different page, - BRANCH - jumps to ; \$9111 |
| \$9111  |       | next OP  | ; V=1 => branch, 4 cycles                             |

#### **CLC**

Operation: Clear Carry flag  $(0 \rightarrow C)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | CLC                       | 18         | 1            | 2             | - | - | - | - | - | - | - | 0 |

Table (17): CLC – Short Reference

#### Example:

| Address | Address Bytes Mnemon |         |              |
|---------|----------------------|---------|--------------|
| \$9000  | 18                   | CLC     | ,            |
| \$9001  |                      | next OP | ; C is now 0 |



#### **CLD**

Operation: Clear decimal flag  $(0 \rightarrow D)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | CLD                       | D8         | 1            | 2             | - | - | - | - | 0 | - | - | - |

Table (18): CLD – Short Reference

#### Example:

| Address | Bytes | Mnemonic |              |
|---------|-------|----------|--------------|
| \$9000  | D8    | CLD      |              |
| \$9001  |       | next OP  | ; D is now 0 |

#### **CLI**

Operation: Clear interrupt disable flag  $(0 \rightarrow I)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | CLI                       | 58         | 1            | 2             | - | - | - | - | - | 0 | - | • |

Table (19): CLI – Short Reference

#### Example:

| Address | Bytes | Mnemonic |              |
|---------|-------|----------|--------------|
| \$9000  | 58    | CLI      |              |
| \$9001  |       | next OP  | ; I is now 0 |

#### **CLV**

Operation: Clear overflow flag  $(0 \rightarrow O)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | CLV                       | В8         | 1            | 2             | - | 0 | - | - | - | - | - | - |

Table (20): CLV - Short Reference



Example:

| Address | Bytes | Mnemonic |
|---------|-------|----------|
| ·       |       |          |

\$9000 B8 CLV ;

\$9001 ... next OP ; V is now 0

#### **CMP**

Operation: Compare Memory and Accumulator (A - M)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С            |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|--------------|
| Immediate       | CMP # Oper                | C9         | 2            | 2             |   | - | - | - | - | - |   | $\checkmark$ |
| Zero Page       | CMP Oper                  | C5         | 2            | 3             |   | - | - | - | - | - |   |              |
| Zero Page, X    | CMP Oper, X               | D5         | 2            | 4             |   | - | - | - | - | - |   | $\sqrt{}$    |
| Absolute        | CMP Oper                  | CD         | 3            | 4             |   | - | - | - | - | - |   |              |
| Absolute, X     | CMP Oper, X               | DD         | 3            | 4*            |   | - | - | - | - | - |   | $\sqrt{}$    |
| Absolute, Y     | CMP Oper, Y               | D9         | 3            | 4*            |   | - | - | - | - | - |   |              |
| (Indirect, X)   | CMP (Oper, X)             | C1         | 2            | 6             |   | - | - | - | - | - |   |              |
| (Indirect), Y   | CMP (Oper), Y             | D1         | 2            | 5*            |   | - | - | - | - | - |   | $\sqrt{}$    |
| (Indirect) NEW  | CMP (Oper)                | D2         | 2            | 5             |   | - | - | - | - | - |   | $\sqrt{}$    |

<sup>\* =&</sup>gt; Add 1 if page boundary is crossed

Table (21): CMP – Short Reference

#### **CPX**

Operation: Compare Memory and Index X (X - M)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z         | С         |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|-----------|-----------|
| Immediate       | CPX # Oper                | E0         | 2            | 2             |   | - | - | - | - | - | V         | $\sqrt{}$ |
| Zero Page       | CPX Oper                  | E4         | 2            | 3             |   | - | - | - | - | - | V         | V         |
| Absolute        | CPX Oper                  | EC         | 3            | 4             |   | - | - | - | - | - | $\sqrt{}$ | 1         |

Table (22): CPX - Short Reference



#### **CPY**

Operation: Compare Memory and Index Y (Y - M)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С         |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|-----------|
| Immediate       | CPY # Oper                | C0         | 2            | 2             |   | - | - | - | - | - |   | $\sqrt{}$ |
| Zero Page       | CPY Oper                  | C4         | 2            | 3             |   | - | - | - | - | - |   | $\sqrt{}$ |
| Absolute        | CPY Oper                  | CC         | 3            | 4             |   | - | - | - | - | - |   | $\sqrt{}$ |

Table (23): CPY – Short Reference

#### **DEC**

Operation: Decrement Memory by one  $(M - 1 \rightarrow M)$ 

| Addressing Mode | Assem<br>Form | bly Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------|--------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Accumulator NEW | DEC           | A            | 3A         | 1            | 2             |   | - | - | - | - | - | V | • |
| Zero Page       | DEC           | Oper         | C6         | 2            | 5             |   | - | - | - | - | - | V |   |
| Zero Page, X    | DEC           | Oper, X      | D6         | 2            | 6             |   | - | - | - | - | - |   |   |
| Absolute        | DEC           | Oper         | CE         | 3            | 6             |   | - | - | - | - | - | V |   |
| Absolute, X     | DEC           | Oper, X      | DE         | 3            | 7             | V | - | - | - | - | - | V | - |

Table (24): DEC – Short Reference

#### **DEX**

Operation: Decrement index X by one  $(X - 1 \rightarrow X)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | DEX                       | CA         | 1            | 2             |   | - | - | - | - | - |   | - |

Table (25): DEX – Short Reference

Example Implied (assume X=\$01):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | CA    | DEX      | •                         |
| \$9001  |       | next OP  | ; X is now \$00, N=0, Z=1 |



<u>DEX 0000 0001 (\$01)</u> <u>0000 0000 (\$00), N=0, Z=1</u>

#### **DEY**

Operation: Decrement index Y by one  $(Y - 1 \rightarrow Y)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | DEY                       | 88         | 1            | 2             |   | - | - | - | - | - |   | - |

Table (26): DEX – Short Reference

Example Implied (assume Y=\$00):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | 88    | DEY      |                           |
| \$9001  | •••   | next OP  | ; Y is now \$FF, N=1, Z=0 |

DEY 0000 0000 (\$00)

1111 1111 (\$FF), N=1, Z=0

#### **EOR**

Operation: "Exclusive-Or" memory or immediate value with accumulator A (A  $\vee$  M  $\rightarrow$  A)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Immediate       | EOR # Oper                | 49         | 2            | 2             |   | - | - | - | - | - |   | - |
| Zero Page       | EOR Oper                  | 45         | 2            | 3             |   | - | - | - | - | - |   | - |
| Zero Page, X    | EOR Oper, X               | 55         | 2            | 4             |   | - | - | - | - | - |   | - |
| Absolute        | EOR Oper                  | 4D         | 3            | 4             |   | - | - | - | - | - |   | - |
| Absolute, X     | EOR Oper, X               | 5D         | 3            | 4*            |   | - | - | - | - | - |   | - |
| Absolute, Y     | EOR Oper, Y               | 59         | 3            | 4*            |   | - | - | - | - | - |   | - |
| (Indirect, X)   | EOR (Oper, X)             | 41         | 2            | 6             |   | - | - | - | - | - |   | - |
| (Indirect), Y   | EOR (Oper), Y             | 51         | 2            | 5*            |   | - | - | - | - | - |   | - |
| (Indirect) NEW  | EOR (Oper)                | 52         | 2            | 5             |   | - | - | - | - | - |   | - |

\* => Add 1 if page boundary is crossed

Table (27): EOR - Short Reference



Example Immediate (assumed A is \$23):

Address Bytes Mnemonic \$9000 49 63 EOR #\$63

\$9002 ... next OP ; A is now \$40, N=0, Z=0

0110 0011 (\$63) EOR 0010 0011 (\$23)

0100 0000 (\$40), N=0, Z=0

#### **INC**

Operation: Increment Memory by one  $(M + 1 \rightarrow M)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Accumulator NEW | INC A                     | 1A         | 1            | 2             | V | - | - | - | - | - |   | - |
| Zero Page       | INC Oper                  | E6         | 2            | 5             |   | - | - | - | - | - |   | - |
| Zero Page, X    | INC Oper, X               | F6         | 2            | 6             |   | - | - | - | - | - |   | - |
| Absolute        | INC Oper                  | EE         | 3            | 6             |   | - | - | - | - | - |   | - |
| Absolute, X     | INC Oper, X               | FE         | 3            | 7             | V | - | - | - | - | - |   | - |

Table (28): INC - Short Reference

#### **INX**

Operation: Increment index X by one  $(X + 1 \rightarrow X)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | C |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | INX                       | E8         | 1            | 2             | V | - | - | - | - | - |   | - |

Table (29): INX - Short Reference

Example Implied (assume X=\$0C):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | E8    | INX      | •                         |
| \$9001  |       | next OP  | ; X is now \$0D, N=0, Z=0 |

<u>INX 0000 1100 (\$0C)</u> <u>0000 1101 (\$0D), N=0, Z=0</u>



#### INY

Operation: Increment index Y by one  $(Y + 1 \rightarrow Y)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | INY                       | C8         | 1            | 2             |   | - | - | - | - | - |   | - |

Table (30): INY - Short Reference

Example Implied (assume Y=\$FF):

| Address | Bytes | Mnemonic |
|---------|-------|----------|
| \$9000  | C8    | INY      |
| \$9001  |       | next OP  |

INY 1111 1111 (\$FF) 0000 0000 (\$00), N=0, Z=1

#### **JMP**

Operation: Jump to new location ((PC + 1)  $\rightarrow$  PCL, (PC + 2)  $\rightarrow$  PCH)

| Addressing Mode   | Assem<br>Form | bly Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-------------------|---------------|--------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Absolute          | JMP           | Oper         | 4C         | 3            | 3             | - | - | - | - | - | - | - | - |
| (Absolute, X) NEW | JMP           | (Oper, X)    | 7C         | 3            | 6             | - | - | - | - | - | - | - | - |
| Indirect          | JMP           | (Oper)       | 6C         | 3            | 6             | - | - | - | - | - | - | - | - |

Table (31): JMP – Short Reference

In mode "Indirect" JMP fetches the high-order byte of the effective address from the first byte of the next page, if the indirect address location spans a page boundary. The 6502 fetches it from the first byte of the current page.

R65C02: JMP (\$02FF) gets ADL from \$02FF, ADH from \$0300 (6 cycles) 5502: JMP (\$02FF) gets ADL from \$02FF, ADH from \$0200 (5 cycles)



# **JSR**

Operation: Jump to subroutine saving return address  $(PC + 2 \downarrow, (PC + 1) \rightarrow PCH, (PC + 2) \rightarrow PCL)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Absolute        | JSR Oper                  | 20         | 3            | 6             | - | - | - | - | - | - | - | - |

Table (32): JSR – Short Reference

#### Example:

| Address | Bytes    | Mnemonic   |  |
|---------|----------|------------|--|
| \$9000  | 20 72 F0 | JSR \$F072 |  |
| F072    |          | next OP    |  |

# **LDA**

Operation: Load accumulator A with memory or immediate value  $(M \rightarrow A)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N         | V | Е | В | D | I | Z         | С |
|-----------------|---------------------------|------------|--------------|---------------|-----------|---|---|---|---|---|-----------|---|
| Immediate       | LDA # Oper                | A9         | 2            | 2             |           | - | - | - | - | - | $\sqrt{}$ | - |
| Zero Page       | LDA Oper                  | A5         | 2            | 3             | $\sqrt{}$ | - | - | - | - | - | $\sqrt{}$ | - |
| Zero Page, X    | LDA Oper, X               | B5         | 2            | 4             |           | - | - | - | - | - | $\sqrt{}$ | - |
| Absolute        | LDA Oper                  | AD         | 3            | 4             |           | - | - | - | - | - | $\sqrt{}$ | - |
| Absolute, X     | LDA Oper, X               | BD         | 3            | 4*            |           | - | - | - | - | - | $\sqrt{}$ | - |
| Absolute, Y     | LDA Oper, Y               | В9         | 3            | 4*            |           | - | - | - | - | - | V         | - |
| (Indirect, X)   | LDA (Oper, X)             | A1         | 2            | 6             |           | - | - | - | - | - | V         | - |
| (Indirect), Y   | LDA (Oper), Y             | B1         | 2            | 5*            |           | - | - | - | - | - | V         | - |
| (Indirect) NEW  | LDA (Oper)                | B2         | 2            | 5             |           | - | - | - | - | - | $\sqrt{}$ | - |

\* => Add 1 if page boundary is crossed

Table (33): LDA – Short Reference

#### Example Immediate:

| Address | Bytes | Mnemonic  |                           |
|---------|-------|-----------|---------------------------|
| \$9000  | A9 00 | LDA #\$00 | •                         |
| \$9002  |       | next OP   | ; A is now \$00, N=0, Z=1 |



# **LDX**

Operation: Load index X with memory or immediate value  $(M \rightarrow X)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Immediate       | LDX # Oper                | A2         | 2            | 2             |   | - | - | - | - | - |   | - |
| Zero Page       | LDX Oper                  | A6         | 2            | 3             |   | - | - | - | - | - | V | - |
| Zero Page, Y    | LDX Oper, Y               | В6         | 2            | 4             |   | - | - | - | - | - | V | - |
| Absolute        | LDX Oper                  | AE         | 3            | 4             |   | - | - | - | - | - | V | - |
| Absolute, Y     | LDX Oper, Y               | BE         | 3            | 4*            |   | - | - | - | - | - |   | - |

<sup>\* =&</sup>gt; Add 1 if page boundary is crossed

Table (34): LDX – Short Reference

#### Example Immediate:

| Address | Bytes | Mnemonic  |                           |
|---------|-------|-----------|---------------------------|
| \$9000  | A2 8F | LDX #\$8F | •                         |
| \$9002  |       | next OP   | ; X is now \$8F, N=1, Z=0 |

#### **LDY**

Operation: Load index Y with memory or immediate value  $(M \rightarrow Y)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Immediate       | LDY # Oper                | A0         | 2            | 2             |   | - | - | - | - | - |   | - |
| Zero Page       | LDY Oper                  | A4         | 2            | 3             |   | - | - | - | - | - |   | - |
| Zero Page, X    | LDY Oper, X               | B4         | 2            | 4             |   | - | - | - | - | - |   | - |
| Absolute        | LDY Oper                  | AC         | 3            | 4             |   | - | - | - | - | - |   | - |
| Absolute, X     | LDY Oper, X               | BC         | 3            | 4*            |   | - | - | - | - | - |   | - |

<sup>\* =&</sup>gt; Add 1 if page boundary is crossed

Table (35): LDY – Short Reference

#### Example Immediate:

| Address | Bytes | Mnemonic  |                           |
|---------|-------|-----------|---------------------------|
| \$9000  | A0 02 | LDY #\$02 | •                         |
| \$9002  | •••   | next OP   | ; Y is now \$02, N=0, Z=0 |



# **LSR**

Operation: Shift Right One Bit (Memory or Accumulator)  $(0 \rightarrow \boxed{7} \ \boxed{6} \ \boxed{5} \ \boxed{4} \ \boxed{3} \ \boxed{2} \ \boxed{1} \ \boxed{0} \rightarrow C)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С         |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|-----------|
| Accumulator     | LSR A                     | 4A         | 1            | 2             | 0 | - | - | - | - | - | V | $\sqrt{}$ |
| Zero Page       | LSR Oper                  | 46         | 2            | 5             | 0 | - | - | - | - | - | V | $\sqrt{}$ |
| Zero Page, X    | LSR Oper, X               | 56         | 2            | 6             | 0 | - | - | - | - | - | V | $\sqrt{}$ |
| Absolute        | LSR Oper                  | 4E         | 3            | 6             | 0 | - | - | - | - | - | V | $\sqrt{}$ |
| Absolute, X     | LSR Oper, X               | 5E         | 3            | 7             | 0 | - | - | - | - | - | V | V         |

Table (36): LSR – Short Reference

# **NOP**

Operation: No Operation

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | NOP                       | EA         | 1            | 2             | - | - | - | - | - | - | - | - |

Table (37): NOP – Short Reference

#### Example:

| Address | Bytes | Mnemonic |   |
|---------|-------|----------|---|
| \$9000  | EA    | NOP      |   |
| \$9001  | •••   | next OP  | , |



# **ORA**

Operation: "Or" memory or immediate value with accumulator A (A V M  $\rightarrow$  A)

| Addressing Mode | Assembly La<br>Form | anguage | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z         | С |
|-----------------|---------------------|---------|------------|--------------|---------------|---|---|---|---|---|---|-----------|---|
| Immediate       | OR # Oper           | -       | 09         | 2            | 2             |   | - | - | - | - | - |           | - |
| Zero Page       | OR Oper             | -       | 05         | 2            | 3             |   | - | - | - | - | - |           | - |
| Zero Page, X    | OR Oper             | , X     | 15         | 2            | 4             |   | - | - | - | - | - |           | - |
| Absolute        | OR Oper             | -       | 0D         | 3            | 4             |   | - | - | - | - | - | $\sqrt{}$ | - |
| Absolute, X     | OR Oper             | , X     | 1D         | 3            | 4*            |   | - | - | - | - | - | $\sqrt{}$ | - |
| Absolute, Y     | OR Oper             | , Y     | 19         | 3            | 4*            |   | - | - | - | - | - |           | - |
| (Indirect, X)   | OR (Ope             | er, X)  | 01         | 2            | 6             |   | - | - | - | - | - |           | - |
| (Indirect), Y   | OR (Ope             | er), Y  | 11         | 2            | 5*            |   | - | - | - | - | - |           | - |
| (Indirect) NEW  | OR (Ope             | er)     | 12         | 2            | 5             |   | - | - | - | - | - |           | - |

<sup>\* =&</sup>gt; Add 1 if page boundary is crossed

Table (38): OR – Short Reference

#### Example Immediate (assumed A is \$8A):

| Addres           | ss Bytes             | Mnemonic            |                                |
|------------------|----------------------|---------------------|--------------------------------|
| \$9000<br>\$9002 | 09 11                | OR #\$11<br>next OP | ;<br>; A is now \$9B, N=1, Z=0 |
| ψ <b>7</b> 002   | 1000 1010 (\$8A)     | nem 01              | , 11 is now \$50, 14 1, 2 0    |
| OR               | 0001 0001 (\$11)     |                     |                                |
|                  | 1001 1011 (\$9B), N= | =1, Z=0             |                                |

#### **PHA**

Operation: Push accumulator on stack (A  $\downarrow$ )

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | PHA                       | 48         | 1            | 3             | - | - | - | - | - | - | - | - |

Table (39): PHA - Short Reference



#### **PHP**

Operation: Push processor status on stack  $(P \downarrow)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | PHP                       | 08         | 1            | 3             | - | - | - | - | - | - | - | - |

Table (40): PHP – Short Reference

# **PHX**

Operation: Push index register X on stack  $(X \downarrow)$ 

| Addressing Mode    | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|--------------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied <b>NEW</b> | PHX                       | DA         | 1            | 3             | - | - | - | - | - | - | - | - |

Table (41): PHX – Short Reference

# **PHY**

Operation: Push index register Y on stack  $(Y \downarrow)$ 

| Addressing Mode    | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|--------------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied <i>NEW</i> | PHY                       | 5A         | 1            | 3             | - | - | - | - | - | - | - | - |

Table (42): PHY – Short Reference

# **PLA**

Operation: Pull accumulator from stack (A 1)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | C |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | PLA                       | 68         | 1            | 4             | V | - | - | - | - | - |   | - |

Table (43): PLA – Short Reference



# **PLP**

Operation: Pull processor status from stack (P 1)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В   | D     | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|-----|-------|---|---|---|
| Implied         | PLP                       | 28         | 1            | 4             |   |   | I | rom | Stack | ( |   |   |

Table (44): PLP – Short Reference

# **PLX**

Operation: Pull index register X from stack  $(X \uparrow)$ 

| Addressing Mode    | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|--------------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied <b>NEW</b> | PLX                       | FA         | 1            | 4             |   | - | - | - | - | - |   |   |

Table (45): PLX – Short Reference

# **PLY**

Operation: Pull index register Y from stack (Y 1)

| Addressing Mode    | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|--------------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied <i>NEW</i> | PLY                       | 7A         | 1            | 4             |   | - | - | - | - | - | V | - |

Table (46): PLY - Short Reference



**ROL** 

Operation: Rotate one bit left (memory or accumulator) ( 7 6 5 4 3 2 1 0

|   | Г |   |   |   |   |   |   |   |      |
|---|---|---|---|---|---|---|---|---|------|
|   | - |   |   |   |   |   |   |   | , ↓  |
| ( | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ← C) |

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Accumulator     | ROL A                     | 2A         | 1            | 2             |   | - | - | - | - | - | V |   |
| Zero Page       | ROL Oper                  | 26         | 2            | 5             |   | - | - | - | - | - | V |   |
| Zero Page, X    | ROL Oper, X               | 36         | 2            | 6             |   | - | - | - | - | - | V |   |
| Absolute        | ROL Oper                  | 2E         | 3            | 6             |   | - | - | - | - | - | V | V |
| Absolute, X     | ROL Oper, X               | 3E         | 3            | 7             |   | - | - | - | - | - | 1 | 1 |

Table (47): ROL – Short Reference

**ROR** 

Operation: Rotate one bit right (memory or accumulator) (C  $\rightarrow$  7 6 5 4 3 2 1 0

| Addressing Mode | Assembly<br>Form | Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С         |
|-----------------|------------------|----------|------------|--------------|---------------|---|---|---|---|---|---|---|-----------|
| Accumulator     | ROR A            |          | 6A         | 1            | 2             |   | - | - | - | - | - |   | $\sqrt{}$ |
| Zero Page       | ROR Op           | per      | 66         | 2            | 5             |   | - | - | - | - | - |   | $\sqrt{}$ |
| Zero Page, X    | ROR Op           | per, X   | 76         | 2            | 6             |   | - | - | - | - | - |   | $\sqrt{}$ |
| Absolute        | ROR Op           | per      | 6E         | 3            | 6             |   | - | - | - | - | - |   | $\sqrt{}$ |
| Absolute, X     | ROR Op           | per, X   | 7E         | 3            | 7             |   | - | - | - | - | - |   | V         |

Table (48): ROR – Short Reference

#### **RMB**

Operation: Reset memory bit x. Where x = 0-7 MSB of op code  $(0 \rightarrow Mx)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page NEW   | RMB(0-7) Oper             | 07-77      | 2            | 5             | - | - | - | - | - | - | - | - |

Table (49): RMB – Short Reference

Example Zero Page:

| Address | Bytes | Mnemonic  |                      |
|---------|-------|-----------|----------------------|
| \$9000  | 37 14 | RMB3 \$14 | ; \$0014 = \$C9      |
| \$9002  |       | next OP   | ; \$0014 is now \$C1 |



# **RTI**

Operation: Return from interrupt  $(P \uparrow, PC \uparrow)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В   | D     | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|-----|-------|---|---|---|
| Implied         | RTI                       | 40         | 1            | 6             |   |   | F | rom | Stack | ζ |   |   |

Table (50): RTI – Short Reference

# **RTS**

Operation: Return from subroutine (PC  $\uparrow$ , PC + 1  $\rightarrow$  PC)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | RTS                       | 60         | 1            | 6             | - | - | - | - | - | - | - | - |

Table (51): RTS – Short Reference

# **SBC**

Operation: Substract memory or immediate value from accumulator with borrow (A - M -  $\overline{C} \rightarrow$  A, C)

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z         | С         |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|-----------|-----------|
| Immediate       | SBC # Oper                | E9         | 2            | 2             |   |   | - | - | - | - | V         |           |
| Zero Page       | SBC Oper                  | E5         | 2            | 3             |   |   | - | - | - | - | $\sqrt{}$ | $\sqrt{}$ |
| Zero Page, X    | SBC Oper, X               | F5         | 2            | 4             |   |   | - | - | - | - | V         |           |
| Absolute        | SBC Oper                  | ED         | 3            | 4             |   |   | - | - | - | - | $\sqrt{}$ |           |
| Absolute, X     | SBC Oper, X               | FD         | 3            | 4*            |   |   | - | - | - | - | $\sqrt{}$ |           |
| Absolute, Y     | SBC Oper, Y               | F9         | 3            | 4*            |   |   | - | - | - | - |           |           |
| (Indirect, X)   | SBC (Oper, X)             | E1         | 2            | 6             |   |   | - | - | - | - | $\sqrt{}$ |           |
| (Indirect), Y   | SBC (Oper), Y             | F1         | 2            | 5*            |   |   | - | - | - | - | $\sqrt{}$ | $\sqrt{}$ |
| (Indirect) NEW  | SBC (Oper)                | F2         | 2            | 5             |   |   | - | - | - | - |           | $\sqrt{}$ |

\* => Add 1 if page boundary is crossed

Table (52): SBC – Short Reference



# **SEC**

Operation: Set carry flag  $(1 \rightarrow C)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | SEC                       | 38         | 1            | 2             | - | - | - | - | - | - | - | 1 |

Table (53): SEC – Short Reference

#### Example:

| Address | Bytes | Mnemonic |              |
|---------|-------|----------|--------------|
| \$9000  | 38    | SEC      | •            |
| \$9001  |       | next OP  | ; C is now 1 |

# **SED**

Operation: Set decimal flag  $(1 \rightarrow D)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | C |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | SED                       | F8         | 1            | 2             | - | - | - | - | 1 | - | - | - |

Table (54): CLD – Short Reference

#### Example:

| Address | Bytes | Mnemonic |              |
|---------|-------|----------|--------------|
| \$9000  | F8    | SED      |              |
| \$9001  |       | next OP  | ; D is now 1 |

# **SEI**

Operation: Set interrupt disable flag  $(1 \rightarrow I)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | SEI                       | 78         | 1            | 2             | - | - | - | - | - | 1 | - | - |

Table (55): SEI – Short Reference



Example:

| Address | Bytes | Mnemonic |
|---------|-------|----------|
| \$9000  | 78    | SEI      |

\$9001 ... next OP ; I is now 1

# **SMB**

Operation: Set memory bit x. Where x = 0-7 (MSB – 8) of op code  $(1 \rightarrow Mx)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page NEW   | SMB(0-7) Oper             | 87-F7      | 2            | 5             | - | - | - | - | - | - | - | - |

Table (56): SMB – Short Reference

#### Example Zero Page:

| Address | Bytes | Mnemonic |                      |
|---------|-------|----------|----------------------|
| \$9000  | F7 14 | SMB \$F0 | \$00F0 = \$43        |
| \$9002  |       | next OP  | ; \$00F0 is now \$C3 |

# **STA**

Operation: Store accumulator in memory  $(A \rightarrow M)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page       | STA Oper                  | 85         | 2            | 3             | - | - | - | - | - | - | - | - |
| Zero Page, X    | STA Oper, X               | 95         | 2            | 4             | - | - | - | - | - | - | - | - |
| Absolute        | STA Oper                  | 8D         | 3            | 4             | - | - | - | - | - | - | - | - |
| Absolute, X     | STA Oper, X               | 9D         | 3            | 5             | - | - | - | - | - | - | - | - |
| Absolute, Y     | STA Oper, Y               | 99         | 3            | 5             | - | - | - | - | - | - | - | - |
| (Indirect, X)   | STA (Oper, X)             | 81         | 2            | 6             | - | - | - | - | - | - | - | - |
| (Indirect), Y   | STA (Oper), Y             | 91         | 2            | 6             | - | - | - | - | - | - | - | - |
| (Indirect) NEW  | STA (Oper)                | 92         | 2            | 5             | - | - | - | - | - | - | - | - |

Table (57): STA – Short Reference



# **STX**

Operation: Store index X in memory  $(X \rightarrow M)$ 

| Addressing Mode | Assem<br>Form | bly Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------|--------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page       | STX           | Oper         | 86         | 2            | 3             | - | - | - | - | - | - | - | - |
| Zero Page, Y    | STX           | Oper, Y      | 96         | 2            | 4             | - | - | - | - | - | - | - | - |
| Absolute        | STX           | Oper         | 8E         | 3            | 4             | - | - | - | - | - | - | - | - |

Table (58): STX – Short Reference

# **STY**

Operation: Store index Y in memory  $(Y \rightarrow M)$ 

| Addressing Mode | Assem<br>Form | bly Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|-----------------|---------------|--------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page       | STY           | Oper         | 84         | 2            | 3             | - | - | - | - | - | - | - | - |
| Zero Page, X    | STY           | Oper, X      | 94         | 2            | 4             | - | - | - | - | - | - | - | - |
| Absolute        | STY           | Oper         | 8C         | 3            | 4             | - | - | - | - | - | - | - | - |

Table (59): STY – Short Reference

# **STZ**

Operation: Store value #\$00 in memory (# $\$00 \rightarrow M$ )

| Addressing Mode     | Assemb<br>Form | oly Language | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|---------------------|----------------|--------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page NEW       | STZ            | Oper         | 64         | 2            | 3             | - | - | - | - | - | - | - | - |
| Zero Page, X NEW    | STZ            | Oper, X      | 74         | 2            | 4             | - | - | - | - | - | - | - | - |
| Absolute <i>NEW</i> | STZ            | Oper         | 9C         | 3            | 4             | - | - | - | - | - | - | - | - |
| Absolute, X NEW     | STZ            | Oper, X      | 9E         | 3            | 5             | - | - | - | - | - | - | - | - |

Table (60): STZ - Short Reference



#### TAX

Operation: Transfer accumulator A to index  $X (A \rightarrow X)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | TAX                       | AA         | 1            | 2             |   | - | - | - | - | - |   | - |

Table (61): TAX – Short Reference

Example Implied (assume A=\$5D):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | AA    | TAX      | •                         |
| \$9001  |       | next OP  | ; X is now \$5D, N=0, Z=0 |

#### **TAY**

Operation: Transfer accumulator A to index Y  $(A \rightarrow Y)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | TAY                       | A8         | 1            | 2             |   | - | - | - | - | - |   | - |

Table (62): TAY - Short Reference

Example Implied (assume A=\$89):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | A8    | TAY      | •                         |
| \$9001  |       | next OP  | ; Y is now \$89, N=1, Z=0 |

#### **TRB**

Operation: Test memory with accumulator A and reset memory bits. If the result of  $A \cap M = 0$  then Z = 1, otherwise Z = 0 ( $\overline{A} \cap M \to M$ )

| Addressing Mode     | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|---------------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page NEW       | TRB Oper                  | 14         | 2            | 5             | - | - | - | - | - | - |   | - |
| Absolute <i>NEW</i> | TRB Oper                  | 1C         | 3            | 6             | - | - | - | - | - | - |   | - |

Table (63): TRB - Short Reference



Example Zero Page (assume A=\$03):

<u>Address</u> <u>Bytes</u> <u>Mnemonic</u> \$9000 14 D2 TRB \$D2 ; \$00D2 = \$61

\$9002 ... next OP ; \$00D2 is now \$60, Z=0

0000 0011 (A=\$03)

NOT 1111 1100

AND 0110 0001 (M=\$61)

0110 0000 (\$60) New value for memory

0000 0011 (A=\$03)

AND 0110 0001 (M=\$61)

0000 0001 Z=0 New value for flag Z

#### **TSB**

Operation: Test memory with accumulator A and set memory bits. If the result of  $A \cap M = 0$  then Z = 1, otherwise Z = 0 (A U M  $\rightarrow$  M)

| Addressing Mode     | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|---------------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Zero Page NEW       | TSB Oper                  | 04         | 2            | 5             | - | - | - | - | - | - |   | - |
| Absolute <i>NEW</i> | TSB Oper                  | 0C         | 3            | 6             | - | - | - | - | - | - |   | - |

Table (64): TSB – Short Reference

Example Zero Page (assume A=\$0C):

 Address
 Bytes
 Mnemonic

 \$9000
 04 D2
 TSB \$D2 ; \$00D2 = \$11

 \$9002
 ...
 next OP ; \$00D2 is now \$1D, Z=1

OR 0000 1100 (A=\$0C) OR 0001 0001 (M=\$11)

0001 1101 (\$1D) New value for memory

0000 1100 (A=\$0C)

AND 0001 0001 (M=\$11)

0000 0000 Z=1 New value for flag Z



# **TSX**

Operation: Transfer stack pointer SP to index X (SP  $\rightarrow X$ )

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | TSX                       | BA         | 1            | 2             |   | - | - | - | - | - |   | - |

Table (65): TSX – Short Reference

Example Implied (assume SP=\$F2):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | BA    | TSX      |                           |
| \$9001  |       | next OP  | ; X is now \$F2, N=1, Z=0 |

# **TXA**

Operation: Transfer index X to accumulator A  $(X \rightarrow A)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | TXA                       | 8A         | 1            | 2             |   | - | - | - | - | - |   | - |

Table (66): TXA - Short Reference

Example Implied (assume X=\$00):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | 8A    | TXA      |                           |
| \$9001  |       | next OP  | ; A is now \$00, N=0, Z=1 |

# **TXS**

Operation: Transfer index X to stack pointer SP  $(X \rightarrow SP)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | Е | В | D | Ι | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | TXS                       | 9A         | 1            | 2             | - | - | - | - | - | - | - | - |

Table (67): TXS – Short Reference



Example Implied (assume X=\$E0):

| Address | Bytes | Mnemonic |  |
|---------|-------|----------|--|
| \$9000  | 9A    | TXS      |  |
| \$9001  |       | next OP  |  |

; SP is now \$E0 (all flags are uneffected

# **TYA**

Operation: Transfer index Y to accumulator A  $(Y \rightarrow A)$ 

| Addressing Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles | N | V | E | В | D | I | Z | С |
|-----------------|---------------------------|------------|--------------|---------------|---|---|---|---|---|---|---|---|
| Implied         | TYA                       | 98         | 1            | 2             |   | - | - | - | - | - |   |   |

Table (68): TYA – Short Reference

Example Implied (assume Y=\$14):

| Address | Bytes | Mnemonic |                           |
|---------|-------|----------|---------------------------|
| \$9000  | 98    | TYA      | •                         |
| \$9001  |       | next OP  | ; A is now \$14, N=0, Z=0 |



4

# Registers

This section specifies all internal registers. It should completely cover the interface between the core and the host as seen from the software view.

# **List of Registers**

| Name | Address | Width | Access | Description |
|------|---------|-------|--------|-------------|
|      |         |       |        |             |
|      |         |       |        |             |
|      |         |       |        |             |

**Table 1: List of registers** 

# Register 1 – Description

(You shall choose the style of register you prefer. Do not use both options in one and the same document.)

| Bit # | Access | Description |
|-------|--------|-------------|
|       |        |             |
|       |        |             |
|       |        |             |

Reset Value:

Reg\_Name: 0000h

| 31 | 30 | 29 | 28 | ••• | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
|    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|    |    |    |    |     |   |   |   |   |   |   |   |   |   |

**Table 2: Description of registers** 

Reset Value:

Reg Name: 0000h



5

# Clocks

This section specifies all the clocks. All clocks, clock domain passes and the clock relations should be described.

| Name | Source | Rates (MHz) |     |            | Remarks | Description |
|------|--------|-------------|-----|------------|---------|-------------|
|      |        | Max         | Min | Resolution |         |             |
|      |        |             |     |            |         |             |
|      |        |             |     |            |         |             |
|      |        |             |     |            |         |             |

Table 3: List of clocks

44 of 44



# **Appendix A**

# **Timing Diagrams**



# ADC, SBC



Figure (3): ADC, SBC – Timing Diagram "Immediate"



Figure (4): ADC, SBC - Timing Diagram "Zero Page"





Figure (5): ADC, SBC - Timing Diagram "Zero Page, X"



Figure (6): ADC, SBC - Timing Diagram "Absolute"





Figure (7): ADC, SBC – Timing Diagram "Absolute, X" – no page crossing



Figure (8): ADC, SBC – Timing Diagram "Absolute, X" – page crossing





Figure (9): ADC, SBC - Timing Diagram "Absolute, Y" - no page crossing



Figure (10): ADC, SBC – Timing Diagram "Absolute, Y" – page crossing





Figure (11): ADC, SBC – Timing Diagram "(Indirect, X)"



Figure (12): ADC, SBC - Timing Diagram "(Indirect), Y" - no page crossing





Figure (13): ADC, SBC - Timing Diagram "(Indirect), Y" - page crossing





Figure (14): AND, CMP, CPX, CPY, EOR, LDA, LDX, LDY, ORA - Timing Diagram "Immediate"



Figure (15): AND, BIT, CMP, CPX, CPY, EOR, LDA, LDX, LDY, ORA - Timing Diagram "Zero Page"





Figure (16): AND, CMP, EOR, LDA, LDY, ORA - Timing Diagram "Zero Page, X"



Figure (17): AND, BIT, CMP, CPX, CPY, EOR, LDA, LDX, LDY, ORA – Timing Diagram "Absolute"





Figure (18): AND, CMP, EOR, LDA, LDY, ORA - Timing Diagram "Absolute, X" - no page crossing



Figure (19): AND, CMP, EOR, LDA, LDY, ORA - Timing Diagram "Absolute, X" - page crossing





Figure (20): AND, CMP, EOR, LDA, LDX, ORA - Timing Diagram "Absolute, Y" - no page crossing



Figure (21): AND, CMP, EOR, LDA, LDX, ORA - Timing Diagram "Absolute, Y" - page crossing





Figure (22): AND, CMP, EOR, LDA, ORA – Timing Diagram "(Indirect, X)"



Figure (23): AND, CMP, EOR, LDA, ORA - Timing Diagram "(Indirect), Y" - no page crossing





Figure (24): AND, CMP, EOR, LDA, ORA - Timing Diagram "(Indirect), Y" - page crossing



# BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE



Figure (25): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE - Timing Diagram "no branch, same page"



Figure (26): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE - Timing Diagram "no branch, different page"



#### BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE (cont.)



Figure (27): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE - Timing Diagram "branch, same page"



Figure (28): BCC, BCS, BVC, BVS, BPL, BMI, BEQ, BNE - Timing Diagram "branch, different page"



#### **BRK**



Figure (29): BRK – Timing Diagram "Implied"



# ASL, LSR, ROL, ROR, DEC, INC



Figure (30): ASL A, LSR A, ROL A, ROR A – Timing Diagram "Immediate"



Figure (31): ASL, LSR, ROL, ROR, DEC, INC - Timing Diagram "Zero Page"



#### ASL, LSR, ROL, ROR, DEC, INC (cont.)



Figure (32): ASL, LSR, ROL, ROR, DEC, INC - Timing Diagram "Zero Page, X"



Figure (33): ASL, LSR, ROL, ROR, DEC, INC - Timing Diagram "Absolute"



#### ASL, LSR, ROL, ROR, DEC, INC (cont.)



Figure (34): ASL, LSR, ROL, ROR, DEC, INC - Timing Diagram "Absolute, X"



## CLC, CLD, CLI, CLV, DEX, DEY, INX, INY, SEC, SED, SEI, TAX, TAY, TSX, TXA, TYA



Figure (35): CLC, CLD, CLI, CLV, DEX, DEY, INX, INY, SEC, SED, SEI, TAX, TAY, TSX, TXA, TYA – Timing Diagram



#### **JMP**



Figure (36): JMP – Timing Diagram "Absolute"



Figure (37): JMP – Timing Diagram "Indirect" (must be corrected)



#### **JSR**



Figure (38): JSR – Timing Diagram



## NOP, TXS



Figure (39): NOP, TXS – Timing Diagram



## PLA, PLP



Figure (40): PLA, PLP - Timing Diagram "Implied"



### PHA, PHP



Figure (41): PHA, PHP – Timing Diagram "Implied"



#### **RTI**



Figure (42): RTI – Timing Diagram "Implied"



#### **RTS**



Figure (43): RTS – Timing Diagram "Implied"



### STA, STX, STY



Figure (44): STA, STX, STY - Timing Diagram "Zero Page"



Figure (45): STA, STY – Timing Diagram "Zero Page, X"



#### STA, STX, STY (cont.)



Figure (46): STX - Timing Diagram "Zero Page, Y"



Figure (47): STA, STX, STY – Timing Diagram "Absolute"



#### STA, STX, STY (cont.)



Figure (48): STA – Timing Diagram "Absolute, X"



Figure (49): STA – Timing Diagram "Absolute, Y"



#### STA, STX, STY (cont.)



Figure (50): STA – Timing Diagram "(Indirect, X)"



Figure (51): STA – Timing Diagram "(Indirect), Y"





## **Instruction Table**

|     |   | 0                    | П                         | 2                     | 3                         | 4                     | S                         | 9                     | 7                         | ∞                        | 6                         | A                     | В                         | ၁                     | D                         | E                      | H                         |         |
|-----|---|----------------------|---------------------------|-----------------------|---------------------------|-----------------------|---------------------------|-----------------------|---------------------------|--------------------------|---------------------------|-----------------------|---------------------------|-----------------------|---------------------------|------------------------|---------------------------|---------|
| LSB | F | BBR0<br>ZP<br>3 5*** | BBR1<br>ZP<br>3 S***      | BBR2<br>ZP<br>3 S***  | BBR3<br>ZP<br>3 S***      | BBR4<br>ZP<br>3 S**** | BBR5<br>ZP<br>3 S***      | BBR6<br>ZP<br>3 S***  | BBR7<br>ZP<br>3 S****     | BBS0<br>ZP<br>3 S***     | BBS1<br>ZP<br>3 5***      | BBS2<br>ZP<br>3 S***  | BBS3<br>ZP<br>3 S***      | BBS4<br>ZP<br>3 S***  | BBS5<br>ZP<br>3 S***      | BBS6<br>ZP<br>3 S***   | BBS7<br>ZP<br>3 S****     | F       |
|     | E | ASL<br>ABS           | ASL<br>ABS,X<br>3 7       | ROL<br>ABS<br>3 6     | ROL<br>ABS,X<br>3 7       | LSR<br>ABS<br>3 6     | LSR<br>ABS,X<br>3 7       | ROR<br>ABS<br>3 6     | ROR<br>ABS,X<br>3 7       | STX<br>ABS<br>3 4        | STZ<br>ABS,X<br>3 5       | LDX<br>ABS<br>3 4     | LDX<br>ABS,Y<br>3 4*      | DEC<br>ABS<br>3 6     | DEC<br>ABS,X<br>3 7       | INC<br>ABS<br>3 6      | INC<br>ABS,X<br>3 7       | H       |
|     | D | ORA<br>ABS           | ORA<br>ABS,X<br>3 4*      | AND<br>ABS<br>3 4     | AND<br>ABS,X<br>3 4*      | EOR<br>ABS<br>3 4     | EOR<br>ABS,X<br>3 4**     | ADC<br>ABS<br>3 4+    | ADC<br>ABS,X<br>3 4*+     | STA<br>ABS<br>3 4        | STA<br>ABS,X<br>3 5       | LDA<br>ABS<br>3 4     | LDA<br>ABS,X<br>3 4*      | CMP<br>ABS<br>3 4     | CMP<br>ABS,X<br>3 4*      | SBC<br>ABS<br>3 4+     | SBC<br>ABS,X<br>3 4*+     | D       |
|     | C | TSB<br>ABS           | TRB<br>ABS<br>3 6         | BIT<br>ABS<br>3 4     | BIT<br>ABS,X<br>3 4*      | JMP<br>ABS<br>3 3     |                           | JMP<br>(ABS)<br>3 6   | JMP<br>(ABS,X)<br>3 6     | STY<br>ABS<br>3 4        | STZ<br>ABS<br>3 4         | LDY<br>ABS<br>3 4     | LDY<br>ABS,X<br>3 4*      | CPY<br>ABS<br>3 4     |                           | CPX<br>ABX<br>3 4      |                           | ၁       |
|     | В |                      |                           |                       |                           |                       |                           |                       |                           |                          |                           |                       |                           |                       |                           |                        |                           | В       |
|     | A | ASL<br>Accum         | INC<br>Accum<br>1 2       | ROL<br>Accum<br>1 2   | DEC<br>Accum<br>1 2       | LSR<br>Accum<br>1 2   | PHY<br>Implied<br>1 3     | ROR<br>Accum<br>1 2   | PLY<br>Implied<br>1 4     | TXA<br>Implied<br>1 2    | TXS<br>Implied<br>1 2     | TAX<br>Implied<br>1 2 | TSX<br>Implied<br>1 2     | DEX<br>Implied<br>1 2 | PHX<br>Implied<br>1 3     | NOP<br>Implied<br>1 2  | PLX<br>Implied<br>1 4     | A       |
|     | 6 | ORA<br>IMM<br>2 2    | ORA<br>ABS,Y<br>3 4*      | AND<br>IMM<br>2 2     | AND<br>ABS,Y<br>2 4*      | EOR<br>IMM<br>2 2     | EOR<br>ABS,Y<br>3 4**     | ADC<br>IMM<br>2 2+    | ADC<br>ABS,Y<br>3 4*+     | BIT<br>IMM<br>2 2        | STA<br>ABS,Y<br>3 5       | LDA<br>IMM<br>2 2     | LDA<br>ABS,Y<br>3 4*      | CMP<br>IMM<br>2 2     | CMP<br>ABS,Y<br>3 4*      | SBC<br>IMM<br>2 2+     | SBC<br>ABS,Y<br>3 4*+     | 6       |
|     | 8 | PHP<br>Implied       | CLC<br>Implied<br>1 3     | PLP<br>Implied<br>1 4 | SEC<br>Implied<br>1 3     | PHA<br>Implied<br>1 3 | CLI<br>Implied<br>I 3     | PLA<br>Implied<br>1 4 | SEI<br>Implied<br>1 3     | DEY<br>Implied<br>1 3    | TYA<br>Implied<br>1 3     | TAY<br>Implied<br>1 3 | CLV<br>Implied<br>1 3     | INY<br>Implied<br>I 3 | CLD<br>Implied<br>1 3     | INX<br>Implied<br>1 3  | SED<br>Implied<br>1 3     | 8       |
|     | 7 | RMB0<br>ZP<br>2 5    | RMB1<br>ZP<br>2 5         | RMB2<br>ZP<br>2 5     | RMB3<br>ZP<br>2 5         | RMB4<br>ZP<br>2 5     | RMB5<br>ZP<br>2 5         | RMB6<br>ZP<br>2 5     | RMB7<br>ZP<br>2 5         | SMB0<br>ZP<br>2 5        | SMB1<br>ZP<br>2 5         | SMB2<br>ZP<br>2 5     | SMB3<br>ZP<br>2 5         | SMB4<br>ZP<br>2 5     | SMB5<br>ZP<br>2 5         | SMB6<br>ZP<br>2 5      | SMB7<br>ZP<br>2 5         | 7       |
|     | 9 | ASL<br>ZP<br>2 5     | ASL<br>ZP,X<br>2 6        | ROL<br>ZP<br>2 5      | ROL<br>ZP,X<br>2 6        | LSR<br>ZP<br>2 5      | LSR<br>ZP,X<br>2 6        | ROR<br>ZP<br>2 5      | ROR<br>ZP,X<br>2 6        | STX<br>ZP<br>2 3         | STX<br>ZP,Y<br>2 4        | LDX<br>ZP<br>2 3      | LDX<br>ZP,Y<br>2 4        | DEC<br>ZP<br>2 5      | DEC<br>ZP,X<br>2 6        | INC<br>ZP<br>2 5       | INC<br>ZP,X<br>2 6        | 9       |
|     | 5 | ORA<br>ZP<br>2 3     | ORA<br>ZP,X<br>2 4        | AND<br>ZP<br>2 3      | AND<br>ZP,X<br>2 4        | EOR<br>ZP<br>2 3      | EOR<br>ZP,X<br>2 4        | ADC<br>ZP<br>2 3+     | ADC<br>ZP,X<br>2 4+       | STA<br>ZP<br>2 3         | STA<br>ZP,X<br>2 4        | LDA<br>ZP<br>2 3      | LDA<br>ZP,X<br>2 4        | CMP<br>ZP<br>2 3      | CMP<br>ZP,X<br>2 4        | SBC<br>ZP<br>2 3+      | SBC<br>ZP,X<br>2 4+       | 4 5 6 7 |
|     | 4 | TSB<br>ZP<br>2 5     | TRB<br>ZP<br>2 5          | BIT<br>ZP<br>2 3      | BIT<br>ZP,X<br>2 4        |                       |                           | STZ<br>ZP<br>2 3      | STZ<br>ZP,X<br>2 4        | STY<br>ZP<br>2 3         | STY<br>ZP,X<br>2 4        | LDY<br>ZP<br>2 3      | LDY<br>ZP,X<br>2 4        | CPY<br>ZP<br>2 3      |                           | CPX<br>ZP<br>2 3       |                           | 119     |
|     | 3 |                      |                           |                       |                           |                       |                           |                       |                           |                          |                           |                       |                           |                       |                           |                        |                           | 3       |
|     | 2 |                      | ORA<br>(IND)<br>2 5       |                       | AND<br>(IND)<br>2 5       |                       | EOR<br>(IND)<br>2 5       |                       | ADC<br>(IND)<br>2 5       |                          | STA<br>(IND)<br>2 5       | LDX<br>IMM<br>2 2     | LDA<br>(IND)<br>2 5       |                       | CMP<br>(IND)<br>2 5       |                        | SBC<br>(IND)<br>2 5       | 2       |
|     | 1 | ORA<br>(IND,X)       | ORA<br>(IND),Y<br>2 5*    | AND<br>(IND,X)        | AND<br>(IND),Y<br>2 5*    | EOR<br>(IND,X)        | EOR<br>(IND),Y<br>2 5*    | ADC<br>(IND,X)<br>2 6 | ADC<br>(IND),Y<br>2 5*+   | STA<br>(IND,X)<br>2 6    | STA<br>(IND),Y<br>2 6     | LDA<br>(IND,X)<br>2 6 | LDA<br>(IND),Y<br>2 5*    | CMP<br>(IND,X)<br>2 6 | CMP<br>(IND),Y<br>2 5*    | SBC<br>(IND,X)<br>2 6+ | SBC<br>(IND),Y<br>2 5*+   | 0 1 2   |
|     | 0 | BRK<br>Implied       | BPL<br>Relative<br>2 2*** | JSR<br>ABS<br>3 6     | BMI<br>Relative<br>2 2*** | RTI<br>Implied<br>1 6 | BVC<br>Relative<br>2 2*** | RTS<br>Implied<br>1 6 | BVS<br>Relative<br>2 2*** | BRA<br>Relative<br>2 3** | BCC<br>Relative<br>2 2*** | LDY<br>IMM<br>2 2     | BCS<br>Relative<br>2 2*** | CPY<br>IMM<br>2 2     | BNE<br>Relative<br>2 2*** | CPX<br>IMM<br>2 2      | BEQ<br>Relative<br>2 2*** | 0       |
|     |   | 0                    | -                         | 7                     | ю                         | 4                     | 'n                        | 9                     | 7                         | ∞<br>∞                   | 6                         | A                     | В                         | ၁                     | Ω                         | ы                      | ഥ                         | 1,55    |

+ Add 1 to N if in decimal mode, \* ADD 1 to N if page boundary is crossed
 \*\* Add 1 to N if branch occurs to same page - Add 2 to N if branch occurs to different page



# Index

This section contains an alphabetical list of helpful document entries with their corresponding page numbers.